#### (19)日本国特許庁(JP)

## (12) 公開特許公報(A)

庁内整理番号

(11)特許出願公開番号

# 特開平8-180025

(43)公開日 平成8年(1996)7月12日

(51) Int.Cl.6

識別記号

FΙ

技術表示箇所

G06F 15/16

340 A

9/46

360 C

審査請求 未請求 請求項の数5 OL (全 13 頁)

(21) 出願番号

(22)出願日

特願平6-318105

平成6年(1994)12月21日

(71)出頭人 000003078

株式会社東芝

神奈川県川崎市幸区堀川町72番地

(72) 発明者 岐津 俊樹

東京都肯梅市末広町2丁目9番地 株式会

社東芝青梅工場内

(74)代理人 弁理士 鈴江 武彦

.

## (54) 【発明の名称】 スケジューリング装置

#### (57)【要約】

【目的】アドレス空間を共有するプロセスが同一のプロセッサで実行されるようにスケジューリングするスケジューリング装置を提供する。

【構成】複数のプロセッサ1a~1cがメモリ2を共有するマルチプロセッサシステムであって、アドレス空間を共有する複数のスレッドから構成されるプロセスを実行するマルチプロセッサシステムのスケジューリング装置において、上記スレッドそれぞれが実行されるべきプロセッサを示す情報をプロセス単位にデータ構造5の領域6に格納する手段と、上記プロセッサが実行待ち行列に蓄積されたスレッドを実行する際に、この領域6に格納された情報からそのスレッドが当該プロセッサにて実行であるか否かを判断する手段とを具備し、同一のプロセスに属するスレッドすべてを同一のプロセッサで実行させることを特徴とする。



#### 【特許請求の範囲】

【請求項1】 複数のプロセッサがメモリを共有するマ ルチプロセッサシステムであって、アドレス空間を共有 する複数のスレッドから構成されるプロセスを実行する マルチプロセッサシステムのスケジューリング装置にお いて、

上記スレッドそれぞれが実行されるべきプロセッサを示 す情報をプロセス単位に管理する手段と、上記プロセッ サが実行待ち行列に蓄積されたスレッドを実行する際 に、上記格納された情報からそのスレッドが当該プロセ ッサにて実行可能であるか否かを判断する手段とを具備 し、同一のプロセスに属するスレッドすべてを同一のプ ロセッサで実行させることを特徴とするマルチプロセッ サシステムのスケジューリング装置。

【請求項2】 上記管理手段は、複数のプロセス間でア ドレス空間の共有が発生した際に、このプロセス群単位 に上記スレッドそれぞれが実行されるべきプロセッサを 示す情報を管理する手段を具備し、同一のプロセス群に 属するスレッドすべてを同一のプロセッサで実行させる テムのスケジューリング装置。

【請求項3】 上記管理手段は、複数のプロセス群間で アドレス空間の共有が発生した際に、アドレス空間の共 有を要求した側のプロセスが形成するすべてのプロセス 群の情報をアドレス空間の共有を要求された側のプロセ スが形成するプロセス群の情報に更新する手段を具備 し、アドレス空間を共有するプロセス群に属するスレッ ドすべてを同一のプロセッサで実行させることを特徴と する請求項2記載のマルチプロセッサシステムのスケジ ューリング装置。

【請求項4】 上記管理手段は、いずれかのプロセスが アドレス空間の共有を解消した際に、このプロセスが形 成するプロセス群同士のアドレス空間の共有が解消され るか否かを判定し、プロセス群同士のアドレス空間の共 有が解消される場合に、これらのプロセス群各々に個別 の情報を割り振る手段を具備してなることを特徴とする 請求項3記載のマルチプロセッサシステムのスケジュー リング装置。

【請求項5】 上記管理される情報は、上記複数のプロ セッサのいずれのプロセッサで実行してもかまわない旨 40 を示す情報を含むことを特徴とする請求項1、2、3又 は4記載のマルチプロセッサシステムのスケジューリン グ装置。

#### 【発明の詳細な説明】

#### [0001]

【産業上の利用分野】本発明は、複数のプロセッサがメ モリを共有するマルチプロセッサシステムに適用して好 適なスケジューリング装置に係り、特にキャッシュメモ リや共有メモリの一貫性を保持するためのオーバーヘッ ドを減少させることによりシステム性能の向上を図るこ

とを可能とするスケジューリング装置に関する。

#### [0002]

【従来の技術】従来の複数のプロセッサがメモリを共有 するマルチプロセッサシステムにおいては、共有メモリ を使用することを前提にオペレーティングシステムが作 成されており、通常は、処理性能を向上させるために、 メモリより高速にアクセス可能なキャッシュメモリを設 け、メモリにアクセスした結果をこのキャッシュメモリ に蓄積するようにしている。

【0003】しかし、プロセススケジューラは、複数の プロセス間でアドレス空間を共有している場合でも、ス ケジュールの際にそれを考慮することがなく、そのため にアドレス空間を共有しているようなプロセス同士が別 々のプロセッサで実行されることがあり、このときに共 有しているアドレス空間に書き込み等の更新が行われる と、キャッシュメモリの一貫性を保持するための排他制 御を行う必要が発生し、これがオーバーヘッドとなりシ ステム全体の効率を低下させていた。

#### [0004]

ことを特徴とする請求項1記載のマルチプロセッサシス 20~【発明が解決しようとする課題】上述したように、従来 の複数のプロセッサがメモリを共有するマルチプロセッ サシステムのスケジューリング装置においては、プロセ スをスケジューリングする際に、プロセス間のアドレス 空間の共有を考慮に入れることがなかったため、キャッ シュメモリ及び共有メモリの一貫性を保持するためのオ ーバヘッドを発生させるといった問題があった。

> 【0005】本発明は上記実情に鑑みなされたものであ り、プロセス間でアドレス空間を共有している場合に、 それらのプロセスを同一のプロセッサにスケジューリン グして実行することにより、キャッシュメモリや共有メ モリの一貫性を保持するためのオーバーヘッドを減少さ せ、システム性能の向上を図ることを可能とするスケジ ューリング装置を提供することを目的とする。

### [0006]

【課題を解決するための手段】本発明は、複数のプロセ ッサがメモリを共有するマルチプロセッサシステムであ って、アドレス空間を共有する複数のスレッドから構成 されるプロセスを実行するマルチプロセッサシステムの スケジューリング装置において、上記スレッドそれぞれ が実行されるべきプロセッサを示す情報をプロセス単位 に管理する手段と、上記プロセッサが実行待ち行列に蓄 積されたスレッドを実行する際に、上記格納された情報 からそのスレッドが当該プロセッサにて実行可能である か否かを判断する手段とを具備し、同一のプロセスに属 するスレッドすべてを同一のプロセッサで実行させるこ とを特徴とする。

【0007】また、本発明は、上記管理手段が、複数の プロセス間でアドレス空間の共有が発生した際に、この プロセス群単位に上記スレッドそれぞれが実行されるべ きプロセッサを示す情報を管理する手段を具備し、同一

3

のプロセス群に属するスレッドすべてを同一のプロセッ サで実行させることをすることを特徴とする。

【0008】また、本発明は、上記管理手段が、複数のプロセス群間でアドレス空間の共有が発生した際に、アドレス空間の共有を要求した側のプロセスが形成するすべてのプロセス群の情報をアドレス空間の共有を要求された側のプロセスが形成するプロセス群の情報に更新する手段を具備し、アドレス空間を共有するプロセス群に属するスレッドすべてを同一のプロセッサで実行させることを特徴とする。

【0009】また、本発明は、上記管理手段が、いずれかのプロセスがアドレス空間の共有を解消した際に、このプロセスが形成するプロセス群同士のアドレス空間の共有が解消されるか否かを判定し、プロセス群同士のアドレス空間の共有が解消される場合に、これらのプロセス群各々に個別の情報を割り振る手段を具備してなることを特徴とする。また、本発明は、上記管理される情報が、上記複数のプロセッサのいずれのプロセッサで実行してもかまわない旨を示す情報を含むことを特徴とする。

#### [0010]

【作用】本発明の構成によれば、管理手段が、スレッド、それぞれが実行されるべきプロセッサを示す情報をプロセス単位に管理しており、プロセッサが実行待ち行列に蓄積されたスレッドを実行する際に、この管理された情報を参照して自身が実行可能なスレッドであるか否かを判定する。この判定により実行可能な具体例としては、

- (1) その情報がいずれのプロセッサで実行してもかま わない旨を示している場合。
- (2) その情報が自身のプロセッサを示している場合。 が挙げられる。

【0011】この情報はプロセス単位に管理されるため、同一のプロセスに属するスレッドはすべて同一のプロセッサで実行されることになり、アドレス空間を共有することにより発生するキャッシュメモリや共有メモリの一貫性を保持するためのオーバーヘッドを減少させることができる。

【0012】また、本発明の構成によれば、複数のプロセス間でアドレス空間の共有が発生した際に、上述した管理手段が、アドレス空間を共有するこれら複数のプロセスにより形成されるプロセス群単位にスレッドそれぞれが実行されるべきプロセッサを示す情報を管理する。

【0013】例えば、Aというプロセスが使用するアドレス空間について、B及びCというプロセスが共有を要求した場合、このA、B及びCのプロセスを一つのプロセス群として、このプロセス群単位に情報を管理する。

【0014】これにより、アドレス空間を共有するA、B及びCのプロセスで形成されるプロセス群に属するスレッドはすべて同一のプロセッサで実行されることになり、これらのプロセスがアドレス空間を共有することに

4

より発生するキャッシュメモリや共有メモリの一貫性を 保持するためのオーバーヘッドを減少させることができ る。

【0015】また、本発明の構成によれば、複数のプロセス群間でアドレス空間の共有が発生した際に、上述した管理手段が、アドレス空間の共有を要求した側のプロセスが形成するすべてのプロセス群の情報を、アドレス空間の共有を要求された側のプロセスが形成するプロセス群の情報に更新する。

10 【0016】例えば、いま、A、B及びCにより構成される第1のプロセス群と、X、Y及びZにより構成される第2のプロセス群が存在し、この第1及び第2のプロセス群は、それぞれ個別のプロセッサで実行されるものとする。そして、第2のプロセス群を形成するXのプロセスが、第1のプロセス群を形成するAのプロセスの使用するアドレス空間の共有を要求した場合を考える。

【0017】このとき、管理手段は、Aのプロセスが形成する第1のプロセス群の情報と、Xのプロセスが形成する第2のプロセス群の情報とが等しいか否かを判断 20 し、異なっていれば、第2のプロセス群の情報を第1のプロセス群の情報に更新する。

【0018】この結果、A、B、C、X、Y及び2のプロセスはすべて同一のプロセッサで実行されることになり、A及びXのプロセスがアドレス空間を共有することにより発生するキャッシュメモリや共有メモリの一貫性を保持するためのオーバーヘッドを減少させることができる。

【0019】なお、Xのプロセスが、Y及び2のプロセスと形成する第2のプロセス群以外に他のプロセスとプロセス群を形成していた場合には、そのすべてのプロセス群の情報を、第1のプロセス群の情報に更新することにより、これらのオーバーヘッドを減少させる。

【0020】また、本発明の構成によれば、いずれかのプロセスがアドレス空間の共有を解消した際に、このプロセスが形成するプロセス群同士のアドレス空間の共有が解消されるか否かを判定し、プロセス群同士のアドレス空間の共有が解消される場合に、これらのプロセス群各々に個別の情報を割り振る。

【0021】ここでは、上述したようなA、B及びCにより形成される第1のプロセス群と、X、Y及びZにより形成される第2のプロセス群がアドレス空間を共有している場合、具体的には、A及びXのプロセスがアドレス空間を共有している場合を前提として、このA及びXのプロセスによるアドレス空間の共有が解消された場合を考える。

【0022】このとき、管理手段は、この第1及び第2のプロセス群同士のアドレス空間の共有が解消されるか否かを判定する。この判定でプロセス群同士のアドレス空間の共有の解消が拒否される例としては、さらに、B及びYのプロセスがアドレス空間を共有している場合等

5

が挙げられる。

【0023】そして、プロセス群同士のアドレス空間の 共有が解消される場合には、もはや同じプロセッサで実 行すべき理由がないため、第2のプロセス群の情報を他 の情報に割り振ることが可能となる。この割り振りは、 プロセッサの稼働率に基づく等、所定の規則に従って行 えばよい。これにより、システム全体の効率をより向上 させることが可能となる。

#### [0024]

【実施例】以下図面を参照して本発明の実施例を説明する。まず、図1を参照して本発明の第1実施例を説明する。図1は第1実施例に係るスケジューリング装置の概略構成を示す図である。

【0025】図1に示すように、同実施例に係るスケジューリング装置は、プロセッサ1a~1cと共有メモリ2とがバス3を介して接続されている。また、共有メモリ2には、オペレーティングシステムが実行する際に必要となるデータ群4が格納されている。そして、このデータ群4には、プロセスに関するデータ構造5が含まれ、さらに、このプロセスに関するデータ構造5が含まれている。このスケジューリングに関する情報を格納するための領域6には、各プロセスに属するスレッドが実行されるべきプロセッサのIDが格納される。また、プロセッサ1a~1cのいずれのプロセッサで実行されてもかまわない場合には、その旨を示す値が格納される。

【0026】ここで、あるプロセッサが、実行キューに 投入されたスレッドを処理しようとしたとき、そのプロ セッサは、この領域6に格納された情報を参照して、自 身が実行可能であるか否かを判定する。この場合、領域 6に格納された情報が、

(1) いずれのプロセッサで実行してもかまわない旨を 示している。

(2) その情報が自身のプロセッサを示している。 ときにそのスレッドを実行する。

【0027】これにより、スレッドを実行すべきプロセッサの情報がプロセス単位に管理されることになり、アドレス空間を共有することにより発生するキャッシュメモリや共有メモリの一貫性を保持するためのオーバーへ 40ッドを減少させることができる。

【0028】次に、図2乃至図4を参照して本発明の第2実施例を説明する。図2に示すように、同実施例に係るスケジューリング装置は、プロセッサ1a~1cと共有メモリ2とがバス3を介して接続されている。また、共有メモリ2には、オペレーティングシステムが実行する際に必要となるデータ群4が格納されている。そして、このデータ群4には、プロセスに関するデータ構造5及び複数のプロセス間におけるアドレス空間の共有に関するデータ構造8が含まれ、さらに、このプロセスに50

6

関するデータ構造5には、スケジューリングに関する情報を格納するための領域6とアドレス空間の共有に関するデータ構造8を指し示すポインタ7とが含まれている。

【0029】図3及び図4は、このアドレス空間の共有に関するデータ構造8を具体的に示した概念図である。ここでは、図3に示すように、システム中にプロセス9a、9b及び9cがあり、それらがあるアドレス空間を共有する場合を考える。図4に示すように、これらのプロセスに対応するデータ構造は、それぞれ13a~13cである。そして、このプロセス群に対しprocgroupなるデータ構造11を割り当てる。また、このプロセス群に属する各プロセスに対応してpgsegなるデータ構造12a~12cを割り当てる。そして、これらはリンクされた形で保持される。

【0030】このprocgroup 11は、pgseg データ構造 を指し示すためのポインタであるpg-pgseglink、これを 更新する際に排他制御を行うためのロックであるpg-pgs -eglock、及びこのprocgroup 11に属するプロセスが実 行されるべきプロセッサのIDが格納されるpg-cpuなる メンバにより構成される。一方、pgseg 12a~12c には、次のpgseg 構造を指し示すためのポインタである pgseg-link、procgroup 11を指し示すためのポインタ であるpgseg-pg、及びこのpgseg が属するプロセスのデ ータ構造13a~13cを指し示すためのポインタであ るpgseg-procpなるメンバで構成される。また、各プロ セスのデータ構造13a~13cには、対応するpgseg データ12a~12cを指し示すためのポインタである p-pgsegpなるメンバが存在する。このp-pgsegpは、アド レス空間を共有していない場合には初期値が格納されて いる。

【0031】ここで、図5を参照してプロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明する。図5はプロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明するためのフローチャートである。【0032】まず、オペレーティングシステムは、proc group データ構造11及びpgseg データ構造12a~12cを割り当て(図5のステップA1~A2)、それぞれのデータ構造を適切にリンクすることにより、各メンバの初期化を行う(図5のステップA3)。最後に、オペレーティングシステムは、これらのプロセス群をどのプロセッサで実行すべきかを決定し、procgroup データ構造11のメンバであるpg-cpuにそのプロセッサIDを格納する(図5のステップA4)。

【0033】次に、図6を参照してオペレーティングシステムがスレッドを実行する際の動作手順を説明する。図6はオペレーティングシステムがスレッドを実行する際の動作手順を説明するためのフローチャートである。【0034】実行キューに投入されたスレッドが存在す

7

る場合(図6のステップB1のY)、オペレーティングシステムは、そのスレッドが属するプロセスのデータ構造 $13a\sim13c$  を調べ(図6のステップB2)、メンバp-pgsegpが初期値でない場合には(図6のステップB20N)、対応するpgseg データ構造 $12a\sim12c$ 0 pgseg-pgからprocgroup データ構造11を求め(図6のステップB3)、そのメンバであるpg-cpuを参照して予め設定されたプロセッサIDを認識する(図6のステップB4)。

【0035】ここで、オペレーティングシステムは自身のIDとそのプロセッサIDとが一致しているか否かを判断し(図6のステップB5)、一致していればそのスレッドを実行し(図6のステップB5のY)、不一致であれば、次の実行待ちスレッドについて同様の処理を繰り返す(図6のステップB5のN)。

【0036】これにより、図3に示すプロセス9a、9b及び9cは、同一のプロセッサで実行されることになり、アドレス空間を共有することにより発生するキャッシュメモリや共有メモリの一貫性を保持するためのオーバーヘッドを減少させることができる。

【0037】次に、図7乃至図9を参照して本発明の第3実施例を説明する。図7及び図8は、同実施例におけるアドレス空間の共有に関するデータ構造8を具体的に「示した概念図である。

【0038】ここでは、図7に示すように、システム中にプロセス9a、9b、9c、9d及び9eがあり、それらがあるアドレス空間を共有する場合、具体的には、プロセス9a、9b、9c及び9dがアドレス空間10xを、プロセス9a及び9bがアドレス空間10zをそれぞれ共有する場合を考える。

【0039】図8に示すように、これらのプロセスに対応するデータ構造は、それぞれ $13a\sim13e$ である。そして、このプロセス群それぞれに対しprocgroup なるデータ構造 $11x\sim11z$ を割り当てる。また、このプロセス群に属する各プロセスに対応してpgseg なるデータ構造 $12a1\sim12e$ 1を割り当てる。そして、これらはリンクされた形で保持される。

【0040】このprocgroup  $11x\sim11z$ は、pgseg データ構造を指し示すためのポインタであるpg-pgsegli nk、これを更新する際に排他制御を行うためのロックで あるpg-pgseglock、及びこのprocgroup  $11x\sim11z$  に属するプロセスが実行されるべきプロセッサの IDが 格納されるpg-cpuなるメンバにより構成される。一方、pgseg  $12a1\sim12e1$ には、次のpgseg 構造を指し示すためのポインタであるpgseg-link、同一プロセス内で、別のアドレス空間を共有している場合にそのpgseg データ構造を指し示すためのポインタであるpgseg-plink、procgroup  $11x\sim11z$ を指し示すためのポインタであるpgseg-pg、及びこのpgseg が属するプロセスの

8

データ構造 13a-13e を指し示すためのポインタであるpgseg-procp なるメンパで構成される。また、各プロセスのデータ構造 13a-13e には、対応するpgseg データ 12a1-12e 1を指し示すためのポインタであるp-pgsegpなるメンパが存在する。このp-pgsegpは、アドレス空間を共有していない場合には初期値が格納されている。また、これらすべてのデータ構造を更新する際に排他制御が必要となるが、そのためのロックを示すものがpglock 14 である。

【0041】ここで、図9を参照してプロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明する。図9はプロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明するためのフローチャートである。【0042】初めてアドレス空間の共有が発生した場合には、図5で示した手順により処理を行う。そして、ここでは、既に共有されているアドレス空間に対して新たに共有を要求する場合を説明する。

【0043】この場合、まず、その新たにアドレス空間 20 の共有を要求したプロセスに対応するpgseg データ構造 12a1~12e1を割り当てる(図9のステップC 1)。そして、この割り当てたpgseg データ構造と、アドレス空間に対応したprocgroup データ構造11x~11zとの間をリンクさせ、メンバの初期化を行う(図9のステップC2)。

【0044】ここで、互いに別のアドレス空間を共有し ているプロセス同志が新たにアドレス空間を共有する場 合には(図9のステップC3のY)、双方のデータ構造 を合わせ、グルーピングする必要がある。この際、アド レス空間の共有を要求した側のprocgroup データ構造の 後リンク (pg-forw ) 又は前リンク (pg-back ) をたど り、共有する相手側プロセスの属するprocgroup データ 構造が出現してこないかを確認する(図9のステップC 4~C6)。もし、相手側プロセスの属するprocgroup データ構造が出現した場合には (図9のステップC6の Y)、すでに共有によるデータ構造のグルーピングが行 われていることになるので、新たに処理を行う必要はな い。一方、相手側プロセスの属するprocgroup データ構 造が出現しなかった場合には、グルーピングを行う(図 9のステップC7)。この場合、要求側プロセスの属す るprocgroup データ構造と相手側プロセスの属するproc group データ構造とをリンクさせ、要求側プロセスの属 するprocgroup データ構造すべてのpg-cpuメンバを相手 の属するprocgroup データ構造のpg-cpuメンバに更新す

【0045】これにより、図7に示すプロセス9a、9b、9c、9d及び9eは、同一のプロセッサで実行されることになり、アドレス空間を共有することにより発生するキャッシュメモリや共有メモリの一貫性を保持するためのオーバーヘッドを減少させることができる。

【0046】次に、図10を参照して上述したプロセス間のアドレス空間の共有が解消された場合のオペレーティングシステムの動作手順を説明する。図10はプロセス間のアドレス空間の共有が解消された場合のオペレーティングシステムの動作手順を説明するためのフローチャートである。

【0047】ここでは、図7の状態から、プロセス9dが共有アドレス10xの共有を解消する場合を考える。この場合、まずオペレーティングシステムは、共有の解消するアドレス空間に対応するprocgroup データ構造11xから、pgseg データ構造12d1を取り除く(図10のステップD1)。この際、そのpgseg データ構造が他のprocgroupデータ構造にも存在する場合には、このpgseg データ構造同士のリンクも適切に更新する。この例では、pgseg データ構造12d2が存在するため、このpgsegデータ構造12d2のpgseg-plinkを初期化しておく。

【0048】次に、procgroup データ構造のリンクをた どり、先頭のprocgroup を検索する(図10のステップ D2)。この例では11xが該当する。そして、ここに つながれているすべてのpgseg に対して、各々のpgsegplink をたどり、共有関係のあるprocgroup データ構造 を求め、これをprocgroup データ構造のリンクpg-link に加える。この例では、procgroup データ構造11xか Spg-pgseglinkをたどり、pgseg 12alがまず検索さ れる。そして、このpgseg 12alは、pgseg12a2 に対するリンクをもっているので、pgseg 12a2の属 するprocgroupデータ構造であるprocgroup データ構造 11 z をprocgroup データ構造 11 x のリンクpg-link に加える(図10のステップD4)。オペレーティング システムは、この動作を繰り返し、pgseg 12b1及び pgseg 1.2 c 1 についての処理が終了したら、procgrou p データ構造 1 1 x のpg-link をたどり、次のprocgrou pデータ構造について同様の処理を繰り返す。

【0049】この処理がすべて終了した時点で、プロセス群を分割できる場合には、pg-link でつながれている procgroup 群とつながれていないprocgroup 群とに分かれるので(図10のステップD6のY)、つながれていないprocgroup 群をpg-forw及びpg-back でリンクする(図10のステップD7)。また、つながれているprocgroup 群に対しても、pg-forw 及びpg-back を設定しておくとともに、pg-link を初期化しておく。

【0050】次に、分割されたグループの一方を、適切なプロセッサで実行させるため、pg-cpuを更新する。なお、pg-link でつながれていないprocgroup 群が存在しなかった場合には、分割ができない場合ということにな

10

り、この場合には、pg-form とpg-back を設定してpg-link を初期化する。これにより、システム全体の効率をより向上させることが可能となる。

#### [0051]

【発明の効果】以上詳記したように本発明によれば、プロセス間でアドレス空間を共有している場合に、それらのプロセスを同一のプロセッサにスケジューリングして実行することにより、キャッシュメモリや共有メモリの一貫性を保持するためのオーバーヘッドを減少させ、システム性能の向上を図ることが可能となる。

【0052】また、同一プロセッサで実行すべき必要性がなくなった場合に、実行プロセッサを適切に割り振るため、システム全体の効率をより向上させることが可能となる。

#### 【図面の簡単な説明】

【図1】本発明の第1実施例に係るスケジューリング装置の概略構成を示す図。

【図2】本発明の第2実施例に係るスケジューリング装置の概略構成を示す図。

20 【図3】第2実施例におけるアドレス空間の共有に関するデータ構造を具体的に示した概念図。

【図4】第2実施例におけるアドレス空間の共有に関するデータ構造を具体的に示した概念図。

【図5】プロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明するためのフローチャート。

【図6】オペレーティングシステムがスレッドを実行する際の動作手順を説明するためのフローチャート。

【図7】第3実施例におけるアドレス空間の共有に関するデータ構造を具体的に示した概念図。

【図8】第3実施例におけるアドレス空間の共有に関するデータ構造を具体的に示した概念図。

【図9】プロセス間でアドレス空間の共有が起こった場合のオペレーティングシステムの動作手順を説明するためのフローチャート。

【図10】プロセス間のアドレス空間の共有が解消された場合のオペレーティングシステムの動作手順を説明するためのフローチャート。

#### 【符号の説明】

40 1 a~1 c …プロセッサ、2 …共有メモリ、3 …バス、4 …オペレーティングシステムが使用するデータ群、5 …プロセスに関するデータ構造、6 …スケジュールに関する情報を格納するための領域、7 …アドレス空間の共有に関するデータ構造へのポインタ、8 …アドレス空間の共有に関するデータ構造。







【図4】



【図5】







【図8】



【図9】



【図10】

